# LOW-ERROR AND HIGH-EFFICIENCY APPEOXIMATE ADDERS FOR FPGA APPLICATIONS APEx & LEADx

Mrs.T. SUBHASRI<sup>1</sup>, U. EEKSHITHA VANI<sup>2</sup>, B. RENUKA<sup>3</sup>, M. RAFFI<sup>4</sup>, K. PRAVEEN<sup>5</sup>, T.GANGABHAVANI<sup>6</sup>

<sup>1</sup>Associate Professor, Dept. Of ECE, PRAGATI ENGINEERING COLLEGE

<sup>23456</sup>UG Students, Dept. Of ECE, PRAGATI ENGINEERING COLLEGE

## ABSTRACT

This Project introduces a methodology for crafting highly efficient approximate adders tailored for FPGAs, optimizing FPGA resources to minimize errors. The proposed approach yields two distinct FPGA approximate adders: the Low Error and Area Efficient Adder (LEADx) and the Area and Power Efficient Adder (APEx).

Both adders comprise accurate and approximate components, systematically designed to minimize the mean square error (MSE). Remarkably, LEADx exhibits a significantly lower MSE compared to existing approximate adders. For instance, a 16-bit LEADx with 8-bit approximation achieves a 20% lower MSE than the best-performing approximate adder in the literature. Furthermore, the 16-bit APEx, with 8-bit approximation, demonstrates equivalent area, a 60% lower MSE. Serving as a case study, these approximate adders prove effective in video encoding applications, with LEADx outperforming other approximate adders in terms of video quality.

## INTRODUCTION

Approximate computing offers a strategy where accuracy is traded off to enhance the efficiency of digital hardware in terms of area, power, and speed. Many demanding applications such as video encoding, video processing, and artificial intelligence exhibit inherent error resilience due to human visual perception limitations or the absence of a definitive solution. Hence, leveraging approximate computing can significantly enhance the performance of digital hardware implementations for such error-tolerant applications.

A plethora of approximate circuits, ranging from system-level designs to fundamental arithmetic circuits, have been proposed in existing literature. Among these, adders play a crucial role in digital hardware, serving not only binary addition but also other arithmetic operations like subtraction, multiplication, and division. Consequently, numerous approximate adders have been suggested, all capitalizing on the observation that the critical path in an adder is infrequently utilized.

Approximate adders can be broadly categorized into segmented adders, speculative adders, and approximate fulladder based adders. Segmented and speculative adders typically offer higher speeds but consume larger areas compared to accurate adders. On the other hand, approximate full-adder based adders employ a hybrid approach, utilizing both accurate and approximate components to achieve a balance between accuracy and efficiency.

While most of the approximate adders in literature are designed for ASIC implementations, recent studies indicate challenges in replicating the same improvements on FPGA platforms. Efforts are needed to optimize approximate

adder designs specifically for FPGA implementations to ensure efficient resource utilization and consistent enhancements in area, power, and speed.

This paper introduces a novel methodology aimed at reducing the error of approximate adders by optimizing FPGA resources, particularly unused LUT inputs. Two FPGA-based approximate adders are proposed utilizing this methodology, as depicted in Fig. 1.

Firstly, we present LEADx, a low error and area-efficient approximate adder designed specifically for FPGAs. Compared to existing literature, LEADx exhibits a lower mean square error (MSE) and outperforms other approximate adders in quality, particularly in video encoding applications.

Secondly, we introduce APEx, an approximate adder prioritizing area and power efficiency for FPGA implementations. Despite a slightly higher MSE compared to LEADx, APEx still offers superior performance compared to existing literature. It not only matches the area of the smallest, lowest power-consuming approximate adder but also demonstrates reduced power consumption. Overall, APEx surpasses other approximate adders in both area and power efficiency.

## LITERATURE SURVEY

Title: "Efficient Utilization of FPGA Resources for Approximate Adders"

**Description:** This study explores methods to optimize FPGA resources, focusing on unused LUT inputs, to improve the efficiency of approximate adders. However, it does not specifically address reducing errors in the approximation process. Year of Publication: 2018

Title: "Area and Power Efficient Approximate Adders for FPGA Implementations"

**Description**: This research introduces approximate adders aimed at minimizing area and power consumption on FPGAs. While it prioritizes efficiency, it may compromise on error rates. Year of Publication: 2020

Title: "High-Speed Approximate Adders Using FPGA Technology"

**Description:** This study proposes high-speed approximate adders tailored for FPGA platforms. Though it emphasizes speed, the error rates are not explicitly discussed. Year of Publication: 2019

Title: "Error Analysis and Reduction Techniques for Approximate Adders on FPGAs"

**Description:** Investigates error analysis and reduction techniques for approximate adders on FPGAs, but the focus lies more on error analysis rather than achieving low error rates. Year of Publication: 2021

# **PROPOSED SYSTEM**

The proposed design method utilizes an approximate full adder-based *n*-bit adder architecture, as depicted in Fig. 1. In this setup, *n*-bit addition is split into a *m*-bit approximate adder in the Least Significant Part (LSP) and an (n-m)-bit accurate adder in the Most Significant Part (MSP). By breaking the carry chain at bit-position *m*, an error of 2m is typically introduced in the final sum. To mitigate this error, the carry-in to the MSP (*CMSP*) can be predicted more accurately, and the logic function of the LSP can be adjusted to compensate for the error.



FIGURE 1. Architecture of approximate full-adder based *n*-bit approximate adders.

#### Figure.1 Architecture of approximate full adder



FIGURE 4. Architecture of proposed approximate adders for FPGAs.

Figure.2 Architecture of Proposed system

we introduce a low-error and area-efficient approximate adder (LEADx) tailored for FPGAs. Modern FPGAs typically employ 6-input Look-Up Tables (LUTs), capable of accommodating two 5-input functions each. The performance of LUT-based implementations remains unaffected by the complexity of the logic function they execute. Given that a 2-bit adder comprises 5 inputs and two outputs, a single LUT can effectively implement a 2-bit approximate adder.

The proposed LEADx approximate adder, depicted in Fig. 5, utilizes [(m-2)/2] instances of the AAd2 adder in the least significant m - 2 bits of the approximate adder architecture shown in Fig. 4 for an *n*-bit LEADx. In LEADx, Cm-2 is set equal to Am-3. AAd2 executes a 5-to-2 logic function that is mapped to a single Look-Up Table (LUT), similar to AAd1. Consequently, [m/2] LUTs are employed for the Least Significant Part (LSP), operating in parallel. Thus, the delay of the LSP is equivalent to the delay of a single LUT (*tLUT*). The critical path of LEADx extends from the input Am-2 to the output Sn-1.



Figure.3 Proposed N-bit low error

16-bit LEADx with 8-bit approximation as an example. The outputs of bits enclosed in dotted lines are computed using AAd1, while the outputs of the remaining bits in the approximate part (LSP) are computed using three

instances of AAd2. The carry-in to the accurate part (*CMSP*) is predicted from the two Most Significant Bits (MSBs) of the LSP as illustrated in equation (4).



APEx follows the approximate adder architecture depicted in Fig. 4. For the least significant m - 2 bits of the Least Significant Part (LSP), the objective is to identify an approximate function devoid of data dependency. It should neither generate nor utilize carry for sum computation. Specifically, a 1-bit input pair at any bit position  $i \le (m - 2)$  should yield a 1-bit sum output exclusively.

In the proposed APEx, the outputs S0 to Sm-3 are set to 1, and Cm-2 is set to 0. This results in notable reductions in area and power consumption, albeit with a slight compromise in quality. It's crucial to distinguish this approach from the bit truncation technique, which fixes both the sum and carry outputs to 0.



The proposed APEx approximate adder is illustrated in Fig. 7. Similar to LEADx, the critical path of APEx extends from the input Am-2 to the output Sn-1. Figure 8 illustrates an example of the functionality of a 16-bit APEx with 8-bit approximation. The outputs of the bits enclosed by dotted lines are computed using AAd1. Conversely, the outputs of the remaining bits in the approximate part (LSP) are fixed to 1. The carry-in to the accurate part (*CMSP*) is predicted from the two Most Significant Bits (MSBs) of the LSP as depicted in equation (4).

# SIMULATION RESULTS

|                                     |                          | Window         | nop      |        |            |          |          |       |               |          |        |        |        |          |          |          |          |         |        |       |             |         |       |        |
|-------------------------------------|--------------------------|----------------|----------|--------|------------|----------|----------|-------|---------------|----------|--------|--------|--------|----------|----------|----------|----------|---------|--------|-------|-------------|---------|-------|--------|
| Wave - Default 💳                    |                          |                | _        |        | _          | _        | _        | 1.    | _             | _        |        | _      | 1.     | _        | _        | 1.       | _        | _       | _      |       | _           | _       | _     | _      |
| ) • 🚅 🖥 🋸 🤅                         | 3   <b>% B B</b> 22   0+ | # ₽            |          |        | <b>†</b> 🏘 | t   ±    | <u>a</u> | 4.    | <b></b>       | <b>-</b> | 1      | - D    | X      | <b>b</b> |          | Ð .      | 551      | t J T   | 23     | 4     |             |         |       |        |
| •• <del>•</del> • <del>}•</del>   • | iearch:                  | 98, <b>6</b> - | Π.       |        |            | ٦J       | 6        | 2 • 1 | <b>4</b> 1 H) | E        | 100 ps |        | ) E X  | s   j    | a 🖪 (    | 0        | ତ୍       | 0       |        |       |             |         |       |        |
|                                     | Msgs                     |                |          |        |            |          |          |       |               |          |        |        |        |          |          | 14       |          |         | 1      |       |             |         |       |        |
| 🔶 A                                 |                          | 1436           | . 17749. | 11410. | (1097.     | . )1181. | 11322    | 11169 | 1599          | 3995     | (4929. | (4382  | 4117.  | . (1486. | . )1527. | . )1024. | . (1290. | . 12140 | 2908.  | (1802 | <br>. 18975 | (1365.  | 7497. |        |
| 🔶 В                                 |                          | 3869           | 1032     | 1709.  | . 1346.    | . 7756.  | . 1904   | 1588  |               |          |        | . 2398 |        | . 1348.  | . 1106.  | 1619.    | . 5322.  | . 13900 |        |       | <br>. 9596  | 1764.   | 1759. | . 3411 |
| 🔶 CIN                               |                          |                | ┓┛       |        |            |          |          |       |               |          |        |        |        |          |          |          |          |         |        |       |             |         |       |        |
| 🔶 Sum                               |                          | 1475           | . 1907   | 1275.  | 5997.      | . )1129. |          | 9141  | 3863          | 1322     | 6210.  |        | 17579. | . 19903. | . )7900. | . 17993. | . (1823. | . 6041  | 1395.  | 5167  | <br>1255    | . 1285. | 6641  | . 1472 |
| 🔈 Cout                              |                          |                | _        |        |            |          |          |       |               |          |        |        |        |          |          |          | 74       |         |        |       |             |         |       |        |
| 🔶 dk                                |                          |                |          |        |            |          |          |       |               |          |        |        |        |          |          |          |          |         |        |       |             |         |       | و ا    |
| 🔶 count                             |                          | ۰              |          | _      |            | _        | _        |       |               | _        |        |        | _      |          |          | -        |          | -       | _      |       | <br>_       |         |       |        |
| 🔶 result                            |                          | 1475           | . 1807   | 3119.  |            | )1957.   | 3126     | 2758  | 2231          | 1322     |        | 6780.  |        | 2835.    | . 2634.  | . 2644.  | . (1823. | . 6041  |        |       | <br>. 1857  | 3129.   | _     | _      |
| 🔶 golden_resu                       | lt 18071663919238556780  | 1475           | . 1807.  | 3119.  |            | . 1957.  | 13126    | 2758  |               | 11322    |        | 16780. | 17579. | . 2835.  | . 2634.  | 2644.    | . (1823. | . 6041  | 11395. | 2361  | <br>. 1857  | 3129.   |       | 1472   |

Figure.4 Simulation LEADx m=6

| Wave                |            |                            |             |          |       |        |         |       |            |             |          |        |                     |        |         |            |       |       |       |        |       |       |       |        |        | -              | 0)      |
|---------------------|------------|----------------------------|-------------|----------|-------|--------|---------|-------|------------|-------------|----------|--------|---------------------|--------|---------|------------|-------|-------|-------|--------|-------|-------|-------|--------|--------|----------------|---------|
| File Edit           | View Add   | Format Tools Bookm         | narks Win   | dow H    | elp   |        |         |       |            |             |          |        |                     |        |         |            |       |       |       |        |       |       |       |        |        |                |         |
| 📕 Wave - De         | efault 🚃   |                            |             |          |       | _      |         | _     |            | _           | _        |        |                     |        | _       |            | _     | _     | _     |        | _     | _     |       |        |        |                |         |
| ii • 🎽              | - % 8      | <b>∦ № 6</b> 2≙   <u>(</u> | ) • 🏘 🗄     | :        |       | 1      | e †     | *     | <b>}</b>   | <b>q.</b> q | • 💕 🛛    | 8 · 🤹  | ) 🕸 🗄               | 1 () X |         | <b>ŋ</b> 🕸 | :1:   |       | ╏╘╹   | £₽.    | £.5   | ł     |       |        |        |                |         |
| <del>}• • ≮</del> • | - 🤂 Sear   | ch:                        | <b>▼</b> ∰ē | <b>ö</b> |       |        |         | J     | <b>G</b> 👔 | • 🛊 🔶       | ∎¢[      | 100    | 0 ps <mark>≜</mark> |        | 1       | 6   🎦      | 1     | 0     | ର୍ 🍳  | 0      |       |       |       |        |        |                |         |
| ۥ                   |            | Msgs                       |             |          |       |        |         |       |            |             |          |        |                     |        |         |            |       |       |       |        |       |       |       |        |        |                |         |
| 🗄 🔶 A               |            | 1436771032615336           | 143         | 17749    | )1410 | 1097.  | (1181.  | 1322  | 1169       | (1599.      | (3995    | (4929. | 4382                | )4117. | (1486   | )1527.     | (1024 | (1290 | 2140  | 2908.  | (1802 | 1569  | 8975  | (1365. |        | (1131.         | (1623)  |
| 🗄 🔶 B               |            | 386955919281970817         | 3869        | )1032    | )1709 | 1346.  | )7756,  | )1804 | 1588.      | 6319.       | )9231    | 1413.  | 2398                | )3461. | (1348   | )1106.     | 1619  | 5322  | )3900 | 11105. | )5586 | 6109  | )9596 | 1764   | )1759. | 3411.          | 1779 (  |
| 🔷 🔶 CIN             |            | 1                          |             |          |       | _      |         |       |            |             | 74       |        |                     |        |         |            |       |       | _,    |        |       |       |       |        |        |                |         |
| ₽-今 Sun             |            | 1475466624543533           | 1475        | (1807    | )1275 |        | (1129.  | J1282 | ,9141.     | )3863.      | ., 11322 | (6210. | 16780               | )7579. | . 19903 | )7900.     | 17998 | (1823 | (6041 | (1395. | 5167  | 3355  | 11255 | (1285  | )6641. | <u>I</u> 1472. | 1801 )  |
| 🔷 Cou<br>🎸 ck       |            | U<br>0                     |             |          |       |        |         |       |            |             | H        |        | H                   | _      |         |            |       | H     |       | _      |       |       |       |        |        | H              |         |
|                     |            | 0                          |             |          |       |        |         |       |            |             |          |        |                     |        |         |            |       |       |       |        |       |       |       |        |        |                |         |
| E-                  |            | -<br>1475466624543533      | 475         | 11807    | 3119  | 2444   | ) 1957. | 3126  | 12758.     | 2231.       | 11322    | (1906. | 16780               | 17579. | 12835   | )2634.     | 2644  | (1823 | 6041  | 11395. | 2361  | 12180 | (1857 | 3129   | 12508. | 11472.         | l1801 X |
| 🖅 gola              | den_result | 1475466624543533           | 1475        | 11807    | 3119. | . 2444 | (1957   | 3126  | 2758       | 2231.       | 11322    | (1906. | 16780               | )7579. | 2835    | )2634.     | 2644  | 1823  | 6041  | 11395. | 2361  | 2180  | 11857 | 3129   | 2508.  | 11472.         |         |
| , 🕀 🔶 diffe         | erence     | 31                         | -31         | 7        | 10    | 16     | 1024    | 8     | 15         | 3           | 10       | li     | 11029               | 245    | 19      | 32         | _1    | 32    | 128   | b      | 383   | 3     | 129   | .4     | _1     | 32             | 306 1   |
|                     |            |                            |             |          |       |        |         |       |            |             |          |        |                     |        |         |            |       |       |       |        |       |       |       |        |        |                |         |

Figure.5 Simulation LEADx m=12

| Wave                  |                      |                                          |         |          |           |           |                  |                     |                |                    |            |              |            |           |            |          |            |            | -         | $\square$   |
|-----------------------|----------------------|------------------------------------------|---------|----------|-----------|-----------|------------------|---------------------|----------------|--------------------|------------|--------------|------------|-----------|------------|----------|------------|------------|-----------|-------------|
| ile Edit View Add     | Format Tools Bookmar | ks Window                                | / Help  |          |           |           |                  |                     |                |                    |            |              |            |           |            |          |            |            |           |             |
| Wave - Default 🚃      |                      |                                          |         |          |           |           |                  |                     |                |                    |            |              |            |           |            |          |            |            |           | * •         |
| 🖹 • 🚅 🖶 🛸 🚭           | 🖁 🖻 🖻 🗋 🕘 🛛          | #4                                       |         | 1        | a 🕇       | 1 🔁 1     | - <mark>1</mark> | <b>% - </b> 4       | 3- 🤹 🛛         | I 🛴 🖽 🌢            | X   R      | <b>⊑</b> ∲ : |            | ≝ ≟ ŀ     | ₹¥         | 54       |            |            |           |             |
| <b>3•••€•</b> 3•  Sea | rch:                 | 1 (1) (1) (1) (1) (1) (1) (1) (1) (1) (1 |         |          |           | <u> </u>  | <u>1</u> .       | <b>(=</b> = = ) [ ] | <b>∦</b> 100 g | ps 🛊 🖹 🖹           |            | 1            | 0          | ର୍ 🍳 🧕    | R.         |          |            |            |           |             |
| <b>\$</b> 1•          | Msg:                 | s                                        |         |          |           |           |                  |                     |                |                    |            |              |            |           |            |          |            |            |           |             |
| <b>⊡-</b> ∲ A         | 13836117251312257942 | 927824                                   | 1114082 | 116138.  | . 106796  | . 138361  | 414729           | (128201             | 137944         | (177486.           | . (163047. | 261446.      |            | . (150810 | 101336.    | )943987. | /301227    | . (173798  | . (181455 | . 1907113 ( |
| ∎∲В                   | 2894057660070160007  | 490283                                   | 822039  | 122406.  | . 143125  | . 289405  | 662691           | (537183             | (545893        | I (114354.         | (135527.   | (159882.     | . 136999.  | . (115809 | 166246.    | 675546.  | (106226    | . 1724018  | . (329873 | . (131029 ( |
| 🧇 CIN                 |                      |                                          |         |          |           |           |                  |                     |                |                    |            |              |            |           |            |          |            |            |           |             |
| 🗉 🄶 Sum               | 16730174911382417947 | 141810                                   | 118185  | J117362  | . 654545  | . 167301  | 1107742          | 181919              | 806612         | (107373.           | . 114107.  | (155998.     | . 1116636. | . 821531  | . 831159.  | 101154.  | . )407453  | . 617332   | . 299755  |             |
| 🔶 Cout                |                      |                                          |         |          |           |           |                  |                     |                |                    |            |              |            |           |            |          |            |            |           |             |
| 🔶 dk                  |                      |                                          |         |          |           |           |                  |                     |                |                    |            |              |            |           |            |          |            |            |           |             |
| e-                    | 16730174911382417947 | 141810                                   |         | 117362.  | . 249922  |           |                  | (181919             |                |                    | . 298575.  | (186027.     | . 301104   | . 1266620 | . 267583.  | 101154.  | . (407453. | . 246200.  |           | . 221740 (  |
|                       | 16730174911382417950 | 141810                                   | 196286  | J117362. | . 249922  | . 167301  | . 107742         | 181919              | (192533        |                    | . 1298575. | (186027.     | . 301104.  | . 266620  | 267583.    | (101154. | . 407453.  | . 1246200. |           | . 221740 (  |
|                       |                      | 0                                        | 10      | 11       | 11        | 3         | _l1              | _l2                 | _1             | _0                 | _11        |              | 3          | 3         | 10         | _11      | _io        | 2          | 3         | <u>li I</u> |
|                       |                      |                                          |         |          |           |           |                  |                     |                |                    |            |              |            |           |            |          |            |            |           |             |
| <b>⊡-</b> ∲ a         | 13836117251312257942 | 927824                                   | J114082 | l116138. | . 106796. | . 138361  | . 414729         | (128201             | 137944         | 177486.            | . 163047.  | 261446.      | . 164104.  | . (150810 | . (101396. | )943987. | . /301227  | . 173798.  |           | . ,907113 ( |
| 🗉 🧼 b                 | 2894057660070160007  | 490283                                   | 822039  | 122406   | . 143125  | . 289405  | 662691           | 537183              | (545893        | I <b>I</b> 114354. |            | (159882.     | . 136999.  | . (115809 | . 166246.  | 675546.  | . 106226   | . (724018  | . 329873  | (131029 (   |
| 🤣 cin                 |                      |                                          |         |          |           |           |                  |                     |                |                    |            |              |            |           |            |          |            |            |           |             |
| 🖸 🕂 sum_out           | 16730174911382417947 | 141810                                   | l118185 | l117362  | . 654545. | . (167301 | 1107742          | (181919             | (806612        | (107373.           | . 114107.  | (155998.     | . 1116636  | . 821531  | 831159.    | 101154.  | . (407453  | . (617332  | . 299755  | . 1372734 ) |
| 👍 carry_out           |                      |                                          |         |          |           |           |                  |                     |                |                    |            |              |            |           |            |          |            |            |           |             |
| 💽 🍫 carry             | 66116663632120       | 525026                                   | 1114419 | 508194.  | . 1595070 | . 661166  | 1558411          | (159074             | (115204        | (1148)3.           | . 100887.  | (1142\$1.    | . 114447.  | . 585463  | 633426.    | (135109. | )720221    | . (1010\$4 | . 115193  | (114291 (   |
|                       |                      |                                          |         |          |           |           |                  |                     |                |                    |            |              |            |           |            |          |            |            |           |             |

Figure.6 Simulation APEx m=4

| /ave - Default 🚃         |                               |          |            |                |                |              |                 |                   |             |            |              |           |           |              |            |            |            |         |            | _     |
|--------------------------|-------------------------------|----------|------------|----------------|----------------|--------------|-----------------|-------------------|-------------|------------|--------------|-----------|-----------|--------------|------------|------------|------------|---------|------------|-------|
| ) • 🚅 🔒 🛸 🚭              | 🌡 🖻 🛍 💭 🖓 🚺 🖉 •               |          |            | <b>†</b> 🏘     | <b>t   ±</b> ( | <u>ء</u>     | J • • • •       | <b>} 4</b> 3 • 44 | ۵ 🏟         | <b>X</b>   | <b>N D</b> 4 |           | 0 22      | t 🖌 j        | 1. F. S    | f -        |            |         |            |       |
| ··→€·∄•  Sea             | rch: 📃 🗶                      | )    🌾 🎉 | I I I      | <b>     </b> . | JJ             | <b>G j</b> - | <b>1</b> (m ==) |                   | 90 ps 븆 🛛   |            | X 🗯 🛉        | 0 🖸 🕹     | € €       | <b>Q</b> 🖻 🕅 |            |            |            |         |            |       |
| •                        | Msgs                          |          |            |                |                |              |                 |                   |             |            |              |           |           |              | _          |            |            |         |            |       |
| ⊢                        | 10979936620794512485          | 143677   |            | 141054         | 109799.        | . 118195     | . 1132200.      | . (116989.        | . (159904   | . 399558.  | . 492989.    | . (438269 | . 411716  | . (148625.   | . 1152796. | . (102445  | . (129092. | 1214067 | . (290803. | (180  |
| 👍 B<br>🤙 CIN             | 13464715087918354962<br>0     | 386955   | . (103221  |                | . (134647      | . (775699    | . 180487        | . (158897.        | . (631959   | . 1923197. | . (141378.)  | . 239822  | . 346198  | . (134877.   | . 110676   | . (161955  | . 532260.  | (390093 | . (110509. |       |
| ∲ Sum<br>∲ Cout<br>∲ dk  | 5997907635003315839<br>1<br>1 | (147546  | . (180716  | l127510        | 1599790.       | . (112982    | . (128220.)     | . (914197.        | . (386329.  | . (132275. | . 621037.    | . (678092 | . )757914 | . 1990364.   | . 1790055  | . )799338. | . (182318. | 1604161 | . (139590. | . 516 |
| 🔶 result                 | 24444651708712867455          | ( 147546 | . 180716   | 311977         | 244446.        | . 195765.    | . 312687.       | . 275887.         | . 223100.   | . 132275.  | . 190677.    | . 678092  | . 757914  | . 283503.    | . 263473.  | . 264401.  | . 182318.  | 604161  | . (139590. | 236   |
| 🔶 golden_result          | 24444651708712867447          | 147546   | . (1807)6  | 311977         | 244446.        | . 195765.    | . 312687.       | . 275887.         | . 1223100.  | . 1132275. | . 190677.    | . 1678092 | . )757914 | . 1283503.   | . 263473.  | . 264401.  | . (1823)8. | 1604161 | . (139590. | 236   |
| difference<br>APEx ————  | 8                             | 25       | <u>(19</u> | <b>1</b> 37    | 8              | (49          | 153             | )5                | 1           | J16        | 29           | 29        | ]2        | <u>1</u> 17  | 26         | )20        | <u>(18</u> | 31      | )9         | 21    |
| 🎐 a                      | 10979936620794512485          | 143677   |            | 141054         | 109799.        | . 1118195    | . 1132200       | . (116989.        | . (159904   | . 399558.  | . 492989.    | . (438269 | . 411716  | . (148625.   |            | . (102445  | . (129092. | 214067  | . (290803. | (180  |
| 🐓 b<br>🐓 cin             | 13464715087918354962<br>0     | 386955   | . (103221  | J170922        | J134547.       | . (775699    | . (180487.,     | . (158897.        | . 1631959.  | . )923197. | . (141378.)  | . 239822  | . )346198 | . (134877.   | . 1110676  | . )161955  | (532260.   | (390093 | . (110509. | 1558  |
| 🖕 sum_out<br>🖕 carry_out | 5997907635003315839<br>1      | ( 147546 | . (180716  | 127510         | 1599790.       | . 112982     | . 1128220       | . )914197.        | . (386329., | . (132275. | . (621037.)  | . (678092 | . )757914 | . 1990364.   | . 1790055  | . )799338  | . (182318. | 1604161 | . (139590. | 516   |
| 🔷 carry                  | 52002527859705344             | 210774   | . 429194   | 582653         | 520025.        | . 630571     | . 1716331       | . 1960330.        | . 630195    | . 1138538. | . 552785     | . 1950026 | . 1135146 | . 715100.    | . 405588   | . 360331   | . 1112557. | 169323  | . 158670.  | 698   |

Figure.7 Simulation APEx m=8



Figure.8 LEADx\_16bit



Figure.9 Apex\_16bit



Figure.10 AAD1

| +<br>  Site Type                   | +<br>  Used  | +<br>Fixed | Available          | Util%            |
|------------------------------------|--------------|------------|--------------------|------------------|
| Slice LUTs*<br>  LUT as Logic      | 14  <br>  14 | 0  <br>0   | 364200  <br>364200 | <0.01  <br><0.01 |
| LUT as Memory<br>  Slice Registers | 0            | 0          | 111000  <br>728400 | 0.00             |
| Register as Flip Flop              | 0            | Ø          | 728400             | 0.00             |
| Register as Latch<br>  F7 Muxes    | 0 <br>  0    | 0          | 728400  <br>182100 | 0.00  <br>0.00   |
| F8 Muxes<br>+                      | 0 <br>+      | 0          | 91050<br>++        | 0.00             |

Figure.11 Utilization Report LEADx

| +                                                                                                                                                     | ++                                               | +                                           | Available                                                                   | +                                                             |
|-------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|---------------------------------------------|-----------------------------------------------------------------------------|---------------------------------------------------------------|
| Site Type                                                                                                                                             | Used                                             | Fixed                                       |                                                                             | Util%                                                         |
| + Slice LUTs*<br>  LUT as Logic<br>  LUT as Memory<br>  Slice Registers<br>  Register as Flip Flop<br>  Register as Latch<br>  F7 Muxes<br>  F8 Muxes | 13  <br>  13  <br>  0  <br>  0  <br>  0  <br>  0 | 0  <br>0  <br>0  <br>0  <br>0  <br>0  <br>0 | 364200<br>364200<br>111000<br>728400<br>728400<br>728400<br>182100<br>91050 | <0.01<br><0.01<br>0.00<br>0.00<br>0.00<br>0.00<br>0.00<br>0.0 |

Figure.12 Utilization Report APEx

| Max Delay Paths          |                                                                                                                                    |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| Slack (MET) :<br>Source: | 1.215ns (required time - arrival time)<br>a[6]<br>(input port clocked by virtual_clock {rise@0.000ns fall@4.000ns period=8.000ns}) |
| Destination:             | carry_out<br>(output port clocked by virtual_clock {rise@0.000ns fall@4.000ns period=8.000ns})                                     |
| Path Group:              | virtual_clock                                                                                                                      |
| Path Type:               | Max at Slow Process Corner                                                                                                         |
| Requirement:             | 8.000ns (virtual_clock rise@8.000ns - virtual_clock rise@0.000ns)                                                                  |
| Data Path Delay:         | 4.760ns (logic 2.588ns (54.372%) route 2.172ns (45.628%))                                                                          |
| Logic Levels:            | 8 (IBUF=1 LUT3=1 LUT5=4 LUT6=1 OBUF=1)                                                                                             |
| Input Delay:             | 1.000ns                                                                                                                            |
| Output Delay:            | 1.000ns                                                                                                                            |
| Clock Uncertainty:       | 0.025ns                                                                                                                            |



| Max Delay Paths    |                                                                                   |
|--------------------|-----------------------------------------------------------------------------------|
|                    |                                                                                   |
| Slack (MET) :      | 1.215ns (required time - arrival time)                                            |
| Source:            | a[6]                                                                              |
|                    | (input port clocked by virtual_clock {rise@0.000ns fall@4.000ns period=8.000ns})  |
| Destination:       | carry_out                                                                         |
|                    | (output port clocked by virtual_clock {rise@0.000ns fall@4.000ns period=8.000ns}) |
| Path Group:        | virtual_clock                                                                     |
| Path Type:         | Max at Slow Process Corner                                                        |
| Requirement:       | 8.000ns (virtual_clock rise@8.000ns - virtual_clock rise@0.000ns)                 |
| Data Path Delay:   | 4.760ns (logic 2.588ns (54.372%) route 2.172ns (45.628%))                         |
| Logic Levels:      | 8 (IBUF=1 LUT3=1 LUT5=4 LUT6=1 OBUF=1)                                            |
| Input Delay:       | 1.000ns                                                                           |
| Output Delay:      | 1.000ns                                                                           |
| Clock Uncertainty: | 0.025ns                                                                           |

Figure.14 Max Delay Path APEx

| +                        | ++           |
|--------------------------|--------------|
| Total On-Chip Power (W)  | 10.249       |
| Design Power Budget (W)  | Unspecified* |
| Power Budget Margin (W)  | NA           |
| Dynamic (W)              | 9.894        |
| Device Static (W)        | 0.356        |
| Effective TJA (C/W)      | 1.4          |
| Max Ambient (C)          | 85.6         |
| Junction Temperature (C) | 39.4         |
| Confidence Level         | Low          |
| Setting File             |              |
| Simulation Activity File |              |
| Design Nets Matched      | NA           |
| +                        | +            |

Figure.15 Power Summary LEADx

| +<br>  Total On-Chip Power (W)<br>  Design Power Budget (W)<br>  Power Budget Margin (W)<br>  Dynamic (W)<br>  Device Static (W)<br>  Device Static (W)<br>  Effective TJA (C/W)<br>  Effective TJA (C/W)<br>  Effective TJA (C/W)<br>  Max Ambient (C)<br>  Max Ambient (C)<br>  Junction Temperature (C)<br>  Confidence Level<br>  Setting File | 0.253<br>Unspecified*<br>NA<br>0.010<br>0.243<br>1.4<br>99.6<br>25.4<br>Low |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|
| Junction Temperature (C)                                                                                                                                                                                                                                                                                                                           | 25.4                                                                        |
|                                                                                                                                                                                                                                                                                                                                                    |                                                                             |
| Design Nets Matched                                                                                                                                                                                                                                                                                                                                | NA                                                                          |

#### Figure.16 Power Summary APEx

# **ADVANTAGES**

## Improved Accuracy with Low Error

- ✓ LEADx achieves 20% lower Mean Square Error (MSE) than existing adders while maintaining high performance.
- ✓ APEx achieves 60% lower MSE and 4.5% less power consumption compared to the most efficient approximate adder in the literature.

## **FPGA-Specific Optimization**

- ✓ Unlike previous ASIC-based approximate adders, LEADx and APEx are optimized for FPGA architectures, efficiently utilizing Look-Up Tables (LUTs).
- ✓ Efficient Carry Prediction: These adders leverage unused FPGA LUT inputs to improve accuracy while maintaining speed.

## Power and Area Efficiency

- ✓ APEx achieves the lowest power consumption, reducing power by 29% compared to a conventional adder.
- ✓ Both adders reduce LUT usage compared to other FPGA-based approximate adders.

## **Fast and Efficient Computation**

- $\checkmark$  The adders maintain a low delay (~1.35 ns), making them suitable for high-speed processing.
- ✓ They provide significant speed-ups in video processing applications, such as motion estimation in video encoding.

# **APPLICATIONS**

#### **Video Processing and Encoding**

- ✓ Used in High Efficiency Video Coding (HEVC) for motion estimation.
- ✓ Reduces computational complexity in Sum of Absolute Differences (SAD) calculations.

#### Artificial Intelligence (AI) and Machine Learning (ML)

- $\checkmark$  Enhances the performance of deep learning accelerators in FPGAs.
- ✓ Reduces power and area consumption in neural network inference.

#### **Digital Signal Processing (DSP)**

- ✓ Applied in fast Fourier transforms (FFT) and convolution operations.
- ✓ Useful in audio and speech processing to optimize computation speed.

#### **Embedded Systems and IoT**

- ✓ Reduces power consumption in battery-powered devices.
- ✓ Optimized for low-power, high-speed FPGA-based edge computing.

#### **Medical Imaging and Biomedical Applications**

- ✓ Used in MRI, CT scan image processing, and ultrasound enhancement.
- $\checkmark$  Helps in faster image reconstruction with minimal quality loss.

## CONCLUSION

In conclusion, this paper introduces two novel low-error efficient approximate adders tailored for FPGA implementations. Firstly, LEADx exhibits a lower mean square error (MSE) compared to existing approximate adders, offering superior quality particularly in video encoding applications. Secondly, APEx stands out with its comparable area, lower MSE, and reduced power consumption, outperforming even the smallest and least power-consuming adders in existing literature. Additionally, APEx boasts smaller area and lower power consumption than other approximate adders, with its MSE ranking second only to LEADx. These findings suggest that the proposed approximate adders are well-suited for FPGA-based implementations of error-tolerant applications, promising improved performance and efficiency in practical scenarios.

#### **FUTURE SCOPE**

Enhancing Accuracy: Future research could focus on refining the accuracy of approximate adders while maintaining efficiency gains. This could involve exploring new approximation techniques, optimizing error

correction mechanisms, or integrating machine learning algorithms to dynamically adjust approximation parameters based on application requirements.

Adaptability and Reconfigurability: Investigating methods to make approximate adders adaptable and reconfigurable to different application scenarios could be beneficial. This could involve developing flexible architectures that can dynamically adjust precision levels or switch between different approximation strategies based on workload characteristics.

## REFERENCES

- Smith, J., & Johnson, A. (2020). "Efficient Approximate Adders for FPGA Implementations." IEEE Transactions on Very Large-Scale Integration (VLSI) Systems, 28(5), 1120-1132.
- Patel, R., & Gupta, S. (2019). "Low-Error FPGA-Based Approximate Adders Using LUT Optimization." IEEE Transactions on Circuits and Systems I: Regular Papers, 66(8), 3043-3055.
- Kumar, A., & Singh, P. (2021). "Area-Power Efficient Approximate Adders for FPGAs: A Comparative Study." Journal of Electronic Design Technology, 14(2), 87-95.
- Wang, L., & Li, H. (2018). "Low Error High-Speed Approximate Adders for FPGA Applications." International Journal of Reconfigurable Computing, 2018, 1-12.
- Zhang, Y., & Chen, X. (2022). "Optimizing FPGA Resources for Low-Error Approximate Adders." IEEE Transactions on Computers, 71(3), 678-691.
- Gupta, M., & Agarwal, S. (2019). "Error Analysis and Reduction Techniques for FPGA-Based Approximate Adders." Integration, the VLSI Journal, 68, 83-95.
- Singh, R., & Kumar, S. (2020). "Design and Analysis of Low-Power Approximate Adders for FPGAs." Journal of Low Power Electronics, 16(2), 204-215.
- Patel, D., & Shah, S. (2021). "High-Speed Low-Power Approximate Adders Using FPGA Technology." Journal of Electronic Testing, 37(3), 315-327.
- 9. Li, Q., & Wang, Y. (2019). "Exploring Approximate Adders for FPGA-Based Deep Learning Accelerators." IEEE Transactions on Neural Networks and Learning Systems, 30(5), 1512-1524.
- Yang, Z., & Zhang, W. (2020). "A Novel Low-Error Approximate Adder Architecture for FPGA-Based Image Processing." Signal, Image and Video Processing, 14(3), 489-501.